MkCard
A card node, displaying an image, a button-like label and a hover caption.¶
Description
This node requires addtional CSS to work.
Bases: MkTemplate
__init__
¶
__init__(
title: str,
image: str,
*,
caption: str | None = None,
target: LinkableType | None = None,
size: int = CARD_DEFAULT_SIZE,
path_dark_mode: str | None = None,
**kwargs: Any
)
Parameters:
Name | Type | Description | Default |
---|---|---|---|
title
|
str
|
Button text |
required |
image
|
str
|
Card image |
required |
caption
|
str | None
|
Image caption |
None
|
target
|
LinkableType | None
|
Link target. Can be a URL, an MkPage, or an MkNav |
None
|
size
|
int
|
Height/Width of the card |
CARD_DEFAULT_SIZE
|
path_dark_mode
|
str | None
|
Optional alternative image for dark mode |
None
|
kwargs
|
Any
|
keyword arguments passed to parent |
{}
|
Name | Children | Inherits |
---|---|---|
MkTemplate mknodes.templatenodes.mktemplate Node representing a jinja template. |
graph TD
93860740316816["mkcard.MkCard"]
93860738888176["mktemplate.MkTemplate"]
93860744077920["mkcontainer.MkContainer"]
93860744073616["mknode.MkNode"]
93860744080896["node.Node"]
140589822947552["builtins.object"]
93860738888176 --> 93860740316816
93860744077920 --> 93860738888176
93860744073616 --> 93860744077920
93860744080896 --> 93860744073616
140589822947552 --> 93860744080896
/home/runner/work/mknodes/mknodes/mknodes/basenodes/mkcard/metadata.toml
[metadata]
icon = "mdi:square-medium"
status = "new"
name = "MkCard"
group = "image"
[[resources.css]]
filename = "grid.css"
[examples.with_link]
title = "With link"
jinja = """
{{ "Title" | MkCard("https://picsum.photos/300", target="https://phil65.github.io/mknodes/") }}
"""
[examples.with_caption]
title = "With caption"
jinja = """
{{ "Title" | MkCard("https://picsum.photos/300", caption="Caption") }}
"""
[examples.dark_mode_image]
title = "Separate dark mode image"
jinja = """
{{ "Title" | MkCard("https://picsum.photos/300", path_dark_mode="https://picsum.photos/200") }}
"""
[output.markdown]
template = """
{% set image = (node.image ~ "#only-light") if node.path_dark_mode else node.image %}
{% if node.target %}<a href="{{ node.target | get_url }}">
{% endif %}
<div class="card">
<div class="showcase-container">
<img src="{{ image }}" alt="{{ node.title }}" style="width:{{ node.size }}px,height:{{ node.size }}px">
{% if node.path_dark_mode %}<img src="{{ node.path_dark_mode }}#only-dark" alt="{{ node.title }}" style="width:{{ node.size }}px,height:{{ node.size }}px">
{% endif %}
{% if node.caption %}<div class="overlay">{{ node.caption }}</div>
{% endif %}
</div>
<p>
<button>{{ node.title }}</button>
</p>
</div>
{% if node.target %}</a>
{% endif %}
"""